home *** CD-ROM | disk | FTP | other *** search
/ Amiga Format CD 7 / Amiga Format AFCD07 (Dec 1996, Issue 91).iso / serious / shareware / programming / ixemul-complete / ixemul / news < prev    next >
Text File  |  1996-08-17  |  24KB  |  565 lines

  1. ============
  2. VERSION 44.0
  3. ============
  4.  
  5. Kriton Kyrimis updated ixprefs.
  6.  
  7. David Zaroski updated ixtrace.
  8.  
  9. Fixed link count for directories. Thanks to Norbert Pueschel.
  10.  
  11. umask implemented for for open() and mkdir(). Thanks to Norbert Pueschel.
  12.  
  13. Added muFIBB_SET_GID, which will be implemented in the next version
  14. of MultiUser. The old way of handling setgid was confusing and even
  15. potentially dangerous.  Thanks to Norbert Pueschel.
  16.  
  17. Added the translation unix sticky bit -> AmigaDOS h bit. This one is
  18. more for aestaethical reasons, as the h bit is no longer supported in 3.x.
  19. Thanks to Norbert Pueschel.
  20.  
  21. Added a field 'void *u_user;' near the beginning of the user struct which
  22. everybody is free to (ab)use. It can be handy to store task private data
  23. in the user struct, at least, I had to use it recently.
  24.  
  25. Added an ix_amiga.h header, which will contain all amiga specific functions
  26. and macros in ixemul.library and libc.a, together with a description.
  27.  
  28. Profiling has been enhanced. Ixprefs adds a new profiling preference:
  29. either take samples only while your program is running and the PC is within
  30. your program, or take samples while your program is running and if the PC
  31. is outside your program code (e.g. in ixemul or in intuition.library), use
  32. the last function your program entered before calling ixemul or whatever,
  33. or always take samples, even if other programs are running.  Again, the
  34. last recorded function gets the hit in those cases.
  35.  
  36. An array of 100 longs to store the A4 register of shared libraries has been
  37. added to the user struct. This array can be easily increased in future
  38. releases, should the need arise. The first 20 slots are for your own free
  39. use, the other slots should be registered. See the file REGISTRY in the
  40. ixemul source distribution for more details.
  41.  
  42. Fixed yet another path bug. Running a shell script that's placed somewhere
  43. in your PATH from 'make' failed, unless the filename of the script was
  44. absolute.
  45.  
  46. Added vfork_setup_child to libc.a. This is a wrapper intended to make life
  47. just a little bit easier for those who need to use the vfork2()/vfork_resume()
  48. trick. It replaces the old 'ix_resident()/ix_get_vars2()' pair.
  49.  
  50. Fixed more problems with the routines that start a shell script. This time
  51. problems with symbolic links have been fixed.
  52.  
  53. Fixed problems when parsing a pathname of a shell script, preventing the
  54. execution of that script.
  55.  
  56. Replaced the stdio-sources by the NetBSD 44.0 versions, which incidentally
  57. fixed the broken fgetpos function. This change also adds printf() and scanf()
  58. support for the 'long long' datatype.
  59.  
  60. Added support for the O_CASE open() flag: this will open an existing file
  61. only if the filenames match using a case-sensitive comparison.
  62.  
  63. fstat() didn't compensate the file time for the current timezone offset.
  64.  
  65. Ixemul now supports the 68010 CPU. Thanks to Pascal Eeftinck for pointing
  66. out that the 68010 uses a 68020-like stackframe.
  67.  
  68. Build the version.[ch] files in the build directory instead of in the
  69. source directory.
  70.  
  71. Fixed fchdir().
  72.  
  73. Changed the machine name as returned by uname() to "m68k". Thanks to Lars
  74. Hecking for this.
  75.  
  76. O_ASYNC I/O is now partially supported: select() will test for this
  77. situation.
  78.  
  79. /dev/tty is now translated to console:.
  80.  
  81. Implemented pseudo-terminals support using the FIFO device.
  82.  
  83. Many, mostly small, changes to become more NetBSD compatible. Where
  84. possible, I've replaced the old sources with the NetBSD 1.1 sources.
  85.  
  86. The select() function has been improved: it is now much faster and works
  87. much better.
  88.  
  89. Using F_SETFL with fcntl() failed if the file wasn't a regular file. It now
  90. also works for pipes and sockets.
  91.  
  92. Requesters that are from ixemul.library or ixnet.library now have the name
  93. of the library as their title, so that you can see that they are from the
  94. library, and not from the application. Thanks to Udo Schnurpfeil for
  95. suggesting this.
  96.  
  97. The tty database functions unfortunately slipped through and weren't
  98. included with 43.1. They are back in 44.0.
  99.  
  100. Implemented mmap() and friends. Of course, any mmap feature that actually
  101. requires a MMU will return an error. But if mmap() is used to load a file
  102. into memory, then it works fine.
  103.  
  104. ============
  105. VERSION 43.2
  106. ============
  107.  
  108. Applied patch from Kamil Iskra to improve ixemul stack extension
  109. handling.
  110.  
  111. ============
  112. VERSION 43.1
  113. ============
  114.  
  115. Ixemul no longer uses async writes. All I/O is now synchronous. This
  116. allowed me to remove several Disable()/Enable() pairs, and actually made
  117. ixemul faster. Apparently the overhead in handling async I/O was
  118. substantial.
  119.  
  120. Applied patches from Jeff Shepherd fixing various problems in the
  121. ixnet.library. Among them improved AS225 passwd handling.
  122.  
  123. Moved the resolver functions out of ixnet.library into libc.a. All programs
  124. that used these functions will have to be recompiled. Very few programs use
  125. these functions, and since they are really higher level functions and do
  126. not belong in a low level library like ixnet, I've moved them.
  127.  
  128. Also moved tty database functions (getttyent() and friends, ttyname() and
  129. ttyslot()) to libc.a, for much the same reason.
  130.  
  131. Added the NetBSD DB sources to libc.a and removed the hacked versions from
  132. ixnet.
  133.  
  134. Replaced various headers with the NetBSD versions. Important for certain
  135. socket-related ioctl defines that were incorrect in the old headers.
  136.  
  137. Added ptrace(GETA4, pid, 0, 0) to obtain the value of the a4 register if
  138. this executable was compiled with -fbaserel or -resident. Needed by gdb to
  139. find out where the data section is.
  140.  
  141. Added ptrace(GETEXENAME, pid, 0, 0) to obtain the name of the current
  142. executable. Useful in scripts that start with '#!/bin/sh' or something
  143. similar. 'argv[0]' as seen by sh is the name of the script, but if you want
  144. to get the pathname of 'sh' itself, you can use this ptrace call.
  145.  
  146. Added setlocale() and ctermid() to libc.a.
  147.  
  148. It is now possible to unlink() a file that is owned by another process
  149. (just like Unix). Gcc uses this to remove temporary files that are actually
  150. owned by cpp (or as). Of course, on the Amiga this is implemented as a
  151. delayed delete, i.e. a flag is set in the 'struct file' to tell ixemul to
  152. delete the file when it is closed by the owner process.
  153.  
  154. Added support for a root ('/') directory. This will only work for programs
  155. that use ixemul.library. So if you start pdksh, 'cd' to the root (cd /) and
  156. use the AmigaDOS command 'list' to view this directory, then you won't get
  157. what you expect. If you use the Unix ls command however, then you will see
  158. all the volumes that you have as top level directories.
  159.  
  160. Removed an old hack in __wait_packet.c that interfered with Ctrl-F
  161. handling.
  162.  
  163. Fixed a bug in fnctl(), F_SETFL.
  164.  
  165. Added AFS, AFSFloppy and PFS support.  Many thanks to the AFS author,
  166. Michiel Pelt, who provided me with the necessary technical information, and
  167. to Kriton Kyrimis for giving some very useful suggestions.
  168.  
  169. Added MultiUserFileSystem support, contributed by Mike Krings. Thanks Mike!
  170.  
  171. Added new function ix_warning: similar to ix_panic, but allows the user to
  172. choose between "Continue" and "Abort". This to work around a case like:
  173.  
  174.     for (;;) crypt();
  175.  
  176. where one couldn't break out of the program because the requester kept
  177. popping up.
  178.  
  179. Fixed -mstackcheck support and fixed buggy baserel-stackextend support.
  180.  
  181. The call socket(AF_UNIX, SOCK_STREAM, 0) no longer crashes if ixnet.library
  182. is not installed.
  183.  
  184. Reorganized Makefiles. I've removed the option to compile each source
  185. separately, instead they are always catenated together. Also, 'make' no
  186. longer starts itself two more times in order to make the library. I've
  187. used GNU make wizardry to let 'make' figure out all the targets by itself.
  188.  
  189. Sigsetjmp and siglongjmp were broken. Fixed.
  190.  
  191. Replaced the old man pages with the new NetBSD manual pages in the original
  192. troff form.
  193.  
  194. Replaced the nice() stub in ix_stub with nice.c from NetBSD.
  195.  
  196. Removed a Delay(100) that was called just before a vfork()ed program finally
  197. terminated.
  198.  
  199. Made h_errno a global variable like errno.
  200.  
  201. At several places in the library the errno variable was reset to 0.
  202. However, the library should (almost) never set errno to 0. This caused
  203. problems with the 'ping' program, where recvfrom set errno to 4, but the
  204. library changed it back to 0 before 'ping' got to see it.
  205.  
  206. Now sets st_uid and st_gid from a 'stat' structure to the effective UID and
  207. GID. Some programs tested these fields and they failed when using
  208. networking support. These fields used to be 0.
  209.  
  210. Reread the global environment variables only when 1) a new program is
  211. started, and 2) the ENV: directory has been changed (i.e., a new setting
  212. was added to ENV:). ENV: used to be read every time a program was started,
  213. whether it was needed or not.
  214.  
  215. Given the shell script s.sh in /ram/t:
  216.  
  217.     #!/bin/sh
  218.     /bin/echo $0
  219.  
  220. 'sh /ram/t/s.sh' produced '/ram/t/s.sh', while typing '/ram/t/s.sh' from
  221. within the pdksh shell produced 'Ram:t/s.sh'. Fixed.
  222.  
  223. Removed a dubious CurrentDir() to a *file* instead of a directory.  While
  224. this is apparently supported for the standard AmigaOS filesystems, not all
  225. third-party filesystems supported this.
  226.  
  227. When you try to use a >68020 ixemul.library on a 68000 Amiga, you now get a
  228. decent message instead of a crash.
  229.  
  230. ============
  231. VERSION 43.0
  232. ============
  233.  
  234. Integrated Jeff Shepherd's networking code. If ixnet.library is installed,
  235. then ixemul.library will use the networking functions from the
  236. ixnet.library, instead of the default dummy implementation. Ixnet.library
  237. works with AS225 and with AmiTCP. It supports both clients and daemons.
  238. A program that uses networking functions is completely shielded from the
  239. AS225 and AmiTCP differences by ixnet.library. That library will take care
  240. of all the details for you. That means that there is no longer any need to
  241. provide two different binaries, one for AS225 and one for AmiTCP.
  242. Furthermore, it is relatively easy to add support for other network
  243. packages. Thanks, Jeff!
  244.  
  245. Added stackchecking and extension code, thanks to Matthias Fleischer.
  246.  
  247. Finalized GDB support.
  248.  
  249. ============
  250. VERSION 42.1
  251. ============
  252.  
  253. Fixed bugs when running non-ixemul programs from tools like pdksh or make.
  254. You could get Enforcer hits and the Ctrl-C support also crashed the Amiga.
  255.  
  256. Use the NetBSD code for the system() function instead of using the Amiga
  257. kernel function SystemTagList. This was the cause of several
  258. incompatibilities when porting Unix programs.
  259.  
  260. Improved termios support (added OPORT and ONLCR flags and the INLCR flag).
  261.  
  262. Fixed ptrace handling. Almost none of Leonard's code has survived, I used a
  263. completely different method.
  264.  
  265. Fixed a problem where the name of the current directory, as is visible
  266. by the shell, wasn't changed when a program terminated and ixemul reset the
  267. current directory to its original place.
  268.  
  269. Improved performance somewhat by no longer going through address 4 to get
  270. to the ExecBase structure. Instead, it's copied once to the SysBase
  271. variable, and thereafter only that variable is used. The Enforcer manual
  272. warned against accessing address 4 too often, and ixemul.library did that
  273. a lot.
  274.  
  275. Also improved performance by fixing a busy wait. At one point in the
  276. ixemul, the program cannot continue until a context switch has taken place.
  277. So ixemul waits until the dispatch count of ExecBase has changed,
  278. indicating that a context switch has taken place. By installing a small,
  279. high priority (9) task with body "for (;;) Wait(1 << 31);" and signalling
  280. that task whenever a context switch is needed, I was able to circumvent the
  281. busy wait loop. Because of the high priority of the Task, a context switch
  282. would take place immediately. The task itself goes back to sleep at once,
  283. so there is no time lost there.
  284.  
  285. ============
  286. VERSION 42.0
  287. ============
  288.  
  289. Installed patch in arith.c to work around bug in IEEEDPCmp.  If the first
  290. 32 bits of both doubles are equal, and both doubles are negative, then
  291. the result can no longer be trusted.  Discovered by Bart Van Assche.
  292.  
  293. Ixtrace has been updated to recognize all 42.0 syscalls, thanks to David
  294. Zaroski.
  295.  
  296. Ctrl-C handling worked with KingCON, but not with the standard AmigaDOS
  297. CON-handler (since I use KingCON I never noticed this until it was pointed
  298. out to me by Fred Fish :-). This has now been fixed. See the comments in
  299. library/__read.c for more information.
  300.  
  301. Added the uname() function, written by Lars Hecking.
  302.  
  303. The termios code now properly recognizes the ICRNL input flag for '\r' to
  304. '\n' translation.
  305.  
  306. Fixed a bug in the fcntl() function (actually, in the fcntl.h and
  307. sys/fcntl.h headers).
  308.  
  309. Moved several static variables to user.h, so they are now process-specific.
  310.  
  311. Added profiling support. It was always there, but it was never actually
  312. used.
  313.  
  314. The write() function writes its buffer line-by-line instead of in one big
  315. chunk if the filehandle is the handle of an interactive stream (for
  316. example, a console window). This allows the user to interrupt the output by
  317. pressing a key and it also allows the use of Ctrl-C to break the program.
  318. In previous versions you were unable to stop the output if you forgot to
  319. redirect it to a file. E.g., 'cat /libs/ixemul.library' would essentially
  320. take over the computer.
  321.  
  322. Changed default stack size handling when a new process is launched. It is
  323. either the value of the environment variable IXSTACK, or it inherits the
  324. size from its parent, but if that size is less than 16384, it uses a stack
  325. of 16384 bytes instead.
  326.  
  327. Replaced ixconfig by ixprefs (written by Kriton Kyrimis).
  328.  
  329. Integrated the partial ptrace support from Leonard Norrgard.
  330.  
  331. Removed the gnulib, gnulib-68881 and gnulib-soft-float directories.
  332.  
  333. Compiled with -Wall and fixed (nearly) all warnings. Some warnings are
  334. inevitable and cannot be avoided. -Wall already caught one illegal memory
  335. access bug in __Close()!
  336.  
  337. Added functions to set and get ixemulbase-private information. This will
  338. break older ixconfig's but is much cleaner. Nearly all of the ixemulbase
  339. structure is now off-limits and liable to change without notice! You are
  340. warned! In fact, the structure has been changed already. The library will
  341. complain if a program called 'ixconfig' tries to use it to prevent the user
  342. from using an old ixconfig with the new library.
  343.  
  344. Removed several arithmetic functions dealing with 'long long' types. They
  345. didn't belong in the library, link with libgcc.a instead. Also removed some
  346. arithmetic functions that are never called because they are compiled
  347. directly in 68000 assembly. Don't know why they were ever added.
  348.  
  349. Fixed gen_glue.c so that it no longer generates glue for obsolete functions.
  350.  
  351. Removed ssystem(). ssystem() was the precursor of vfork/execve, and is no
  352. longer needed. NOTE: it is still used in gcc. But this fails spectacularly
  353. once you use Ctrl-C! Delete gcc and replace it by gccv, this one uses
  354. vfork/execve as it should and works perfectly.
  355.  
  356. ixemul.library now uses the new-style inlines.
  357.  
  358. qsort() is now re-entrant and no longer uses the horrible Semaphore hack.
  359.  
  360. Moved general/fts.c to the static library. These directory-tree traversal
  361. functions are rarely, if ever used, so they belong in libc.a and not in a
  362. shared library.
  363.  
  364. Reorganized the Makefiles. The makefiles now use several GNU make-only
  365. features to make them smaller and easier to maintain.  'make clean' and
  366. 'make clobber' now work correctly.  It is also no longer nessecary to add
  367. the -srcdir option to 'sh configure' in order to create valid Makefiles.
  368.  
  369. The top level Makefile contains the line 'export CATENATE = 1'. If this
  370. line is present, the compilation speed is greatly improved by catenating
  371. several small C-sources together into one bigger C-source, and then the
  372. bigger one is compiled. By commenting this line each separate source is 
  373. compiled. Note that besides improving compilation speed, the library also
  374. gets smaller as the compiler can now determine whether a call can be made
  375. relative or should remain absolute.
  376.  
  377. Fixed a symlink-bug (ln -s /ram/t created a symlink to /am/t, removing the
  378. first character of the volumename).
  379.  
  380. Moved ixtrace to the new utils directory, together with the small ixrun
  381. utility.  ixrun can be used to run Amiga batch files from /bin/sh (just put
  382. ';!ixrun' at the second line (!) of the batch file).  Also added manual
  383. page for ixrun.
  384.  
  385. Cleaned up the static directory:  removed xmalloc.c and alloca.c as they do
  386. not belong in the standard C library.  Also replaced the ctime.c source by
  387. the version from elsie.nci.nih.gov, which is the official version used by
  388. NetBSD and Linux, among others.  Finally, errlst.c and siglist.c now just
  389. include their counterparts in the general directory.
  390.  
  391. The version information is placed in the version.in file in the
  392. top-level directory. The version.c and version.h sources are created from
  393. this file.
  394.  
  395. The print_base_size.c and print_user.c sources have been replaced by
  396. create_header.c, which creates a header containing a few defines that are
  397. used by start.s and trap.s. These used to be hard-coded, but now they are
  398. generated, preventing future mistakes.
  399.  
  400. Added the raise function. For some reason, raise.c was never compiled into
  401. the library. It is now.
  402.  
  403. Removed ALL sources that were not needed for compilation.
  404.  
  405. Added timezone handling. The timezone databases from elsie.nci.nih.gov are
  406. used and installed in etc:zoneinfo. The new ixtimezone utility should be
  407. added to the startup-sequence. This utility determines the correct offset
  408. for Greenwich Mean Time. Read the manual page (Yes! Documentation at last!)
  409. for more information.
  410.  
  411. Merged the ixpipe-handler into the ixemul-distribution. It has been placed
  412. in the utils-directory.
  413.  
  414. Added hack to allow ixemul to run AmigaDOS scripts without breaking them
  415. when run from the AmigaDOS shell. The problem is that the ".KEY" string
  416. must be at the first line of the script, while ixemul also looks for "#!"
  417. and ";!" in the first line. If a file starts with ".KEY", ixemul will now
  418. skip the first line, before checking for "#!" and ";!".
  419.  
  420. ============
  421. VERSION 41.4
  422. ============
  423.  
  424. Integrated patches from Hans Verkuil that fix CTRL-C handling, fix another
  425. signal bug, fix problem with "rm -f", prepare for proper timezone handling,
  426. and remove '@' hack in argument parsing.
  427.  
  428. Applied patch from Kamil Iskra to avoid incompatibility between ixemul
  429. and the popular KingCON 1.3.  This is KingCON's fault because it makes
  430. invalid assumptions about the nature of reply port contained in "dp_Port"
  431. of packets sent to it.  Also applied patch (duplicated in Hans' patches)
  432. to crt0.c that fixes bug where the revision requester was not working
  433. properly if the current revision is 0.
  434.  
  435. Applied patch from Rask Lambertsen (duplicated in Hans' patches) that makes
  436. ixemul.library open "CONSOLE:" instead of "*".
  437.  
  438. Added implementation from Kriton Kyrimis for srand48, seed48, lcong48,
  439. lrand48, nrand48, mrand48, jrand48, drand48, and erand48.
  440.  
  441. Added "#include <sys/types.h>" to <dirent.h> to be more compatible
  442. with most current systems that do this inclusion for you.  This change
  443. should be backwards compatible with code that does the inclusion
  444. explicitly.  Suggested by Lars Hecking.
  445.  
  446. Changed prototype in <unistd.h> for getpgrp() to take a pid_t argument,
  447. which matches the implementation in library/getcrap.c.  Suggested by
  448. Lars Hecking.
  449.  
  450. Made change to <math-68881.h> in pow() so that if x<0 the code does
  451. log(-x) rather than log(x).  Suggested by Thomas Radtke and implemented
  452. by Lars Hecking.
  453.  
  454. Disable definitions of F_GETLK, F_SETLK, F_SETLKW, F_RDLCK, F_UNLCK, and
  455. F_WRLCK in <fcntl.h> since they are unimplemented and thus might have misled
  456. autoconfiguration schemes into thinking they were available.  Also fix
  457. ixtrace.c so it will still compile without these defined.  Suggested by
  458. Robert Ramiega.
  459.  
  460. Integrated patch from Joop van de Wege (duplicated in Hans' patches) for
  461. setting up fpu on 68060.
  462.  
  463. ============
  464. VERSION 41.3
  465. ============
  466.  
  467. Updated DBL_MIN and DBL_MAX in float.h to include one additional digit
  468. of precision.  Enclose negative constants in parens to avoid unexpected
  469. conversion to subtraction via cpp macros.
  470.  
  471. Applied patch from Hans Verkuil to fix serious bug in signal handling,
  472. to reset all signal handlers after an execve, except for those which are
  473. being ignored (SIG_IGN).
  474.  
  475. Applied patch from Joop van de Wege to trap.s to set 68881 rounding mode
  476. back to truncation instead of "round to nearest", as required by the
  477. ANSI C standard which specifies truncation.
  478.  
  479. Integrated ixtrace into source tree and arranged for it to be built and
  480. installed.
  481.  
  482. ============
  483. VERSION 41.2
  484. ============
  485.  
  486. Added "#include <sys/types.h>" to <sys/stat.h> to be more compatible
  487. with most current systems that do this inclusion for you.  This change
  488. should be backwards compatible with code that does the inclusion
  489. explicitly.
  490.  
  491. Changed version string to be style guide compliant.  Also arranged that
  492. version.o gets linked in, since it has the $VER: string and is otherwise
  493. unreferenced by any ixemul.library code.
  494.  
  495. Merged patches from Hans Verkuil to fix execve environment passing,
  496. always open the console for stderr if no other file handle is provided,
  497. move AmigaDOS style filename matching into glob(), and fix a small problem
  498. with "open(NULL,...) that caused enforcer hits.
  499.  
  500. ============
  501. VERSION 41.1
  502. ============
  503.  
  504. A 68040 version of the library with soft floating point is now built,
  505. since there are apparently systems that use the versions of the 68040
  506. without FPUs.
  507.  
  508. Fixed crt0 files to use "jra _ENTRY" as first instruction rather than
  509. "jmp pc@(_ENTRY)" which was getting assembled by gas 2.5.2 as a 68020+
  510. instruction.  Note "jmp pc@(_ENTRY:W)" seems to generate the 68000
  511. instruction but a bad jump offset.  Added corresponding change to
  512. execve.c to recognize ixemul using executables with this change.
  513.  
  514. Fixed cpu.h, machdep.c, trap.s to avoid pc relative assembly instruction
  515. that was getting compiled as 68020+ instruction and causing crashes on
  516. 68000 machines.
  517.  
  518. Fixed numerous files that did "#include" of "DEFS.H" rather than "defs.h".
  519. This is an innocuous bug on the Amiga, which is case independent, but
  520. it kills cross compilations.
  521.  
  522. ============
  523. VERSION 41.0
  524. ============
  525.  
  526. No significant changes since the 40.6 beta release other than the
  527. mechanism (and macros) for building debug versions has been cleaned
  528. up and the version number has been bumped to 41.0.
  529.  
  530. Did include the cat'able man pages back in the source tree, but no
  531. work has been done yet to track down the sources for the man pages
  532. and arrange for them to be properly integrated into the tree and
  533. have the cat'able versions generated from those sources.
  534.  
  535. ============
  536. VERSION 40.6
  537. ============
  538.  
  539. Many bugs have been fixed since the 40.4 release, including a serious
  540. one that was causing memory corruption and many enforcer or mungwall
  541. hits.
  542.  
  543. Network support has been reintegrated into the library, however it is
  544. still mostly untested.  In particular, many functions are only
  545. available for static linking from the libnet.a library.  By the next
  546. release, it is expected that libnet.a will be incorporated in libc.a.
  547.  
  548. Work is underway to merge the best features from at least two
  549. different strains of the ixemul library.  Many more changes are
  550. expected by the 41.0 release.
  551.  
  552. An environment variable called "IXSTACK" is now used to control the
  553. stack size of programs started by system().  If the current stack is
  554. smaller than the value in IXSTACK, the stack is raised to the value
  555. specified in IXSTACK.  So IXSTACK is a minimum value.
  556.  
  557. Automatic stack checking, with a requestor if the stack overflows, is
  558. available for executables compiled with a version of gcc that supports
  559. the -mstackcheck option.  This also requires linking with new crt0 and
  560. libc.a.
  561.  
  562. Automatic stack extension as necessary is available for executables
  563. compiled with a version of gcc that supports the -mstackextend option.
  564. This also requires linking with new crt0 and libc.a.
  565.